Requested Patent: JP2003229000A

Title: METHOD AND APPARATUS FOR MEMORY SELF TESTING;

Abstracted Patent: US2003120985;

Publication Date: 2003-06-26;

Inventor(s):

HILL STEPHEN JOHN (US); SLOBODNIK RICHARD (US); WILLIAMS GERARD RICHARD (US);

Applicant(s):

Application Number: US20010025816 20011226;

Priority Number(s): US20010025816 20011226;

IPC Classification: G11C29/00;

Equivalents: GB2383640;

**ABSTRACT:** 

A self-test controller 10 is responsive to scanned in self-test instructions to carry out test operations including generating a sequence of memory addresses that is specified by the self-test instruction. Combining multiple such self-test instructions allows a custom test methodology to be built up by a user using a generic self-test controller 10

# (19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

特開2003-229000

(P2003-229000A) (43)公開日 平成15年8月15日(2003.8.15)

| (51) Int.Cl. <sup>7</sup> |       | 識別記号  | <b>F</b> I |       | 7       | -73-1*(参考) |
|---------------------------|-------|-------|------------|-------|---------|------------|
| G11C                      | 29/00 | 675   | G11C       | 29/00 | 675M    | 2G132      |
| G01R                      | 31/28 |       | G06F       | 12/16 | 3 3 0 A | 5B018      |
| G06F                      | 12/16 | 3 3 0 |            | 15/78 | 510K    | 5B062      |
|                           | 15/78 | 510   | G 0 1 R    | 31/28 | U       | 5 L 1 0 6  |
|                           |       |       |            |       | В       |            |

審査請求 未請求 請求項の数34 OL (全 18 頁)

(21)出願番号 特願2002-288612(P2002-288612)

(22)出顧日 平成14年10月1日(2002.10.1)

(31)優先権主張番号 025816

(32) 優先日 平成13年12月26日(2001.12.26)

(33)優先権主張国 米国 (US)

(71)出願人 594154428

エイアールエム リミテッド

イギリス国 シーピー1 9エヌジェイ

ケンプリッジ, チェリー ヒントン, フル

パーン ロード 110

(72)発明者 リチャード スロボドニク

アメリカ合衆国 テキサス、オースティ

ン、 ビル ポニー コート 108

(74)代理人 100066692

弁理士 浅村 皓 (外3名)

最終頁に続く

# (54) 【発明の名称】 メモリ自己テストの方法と装置

# (57)【要約】

【課題】 メーカや設計方式が異なる種々のメモリの不良を自己テストするのに有用な、プログラム可能な自己テスト・コントローラを提供する。

【解決手段】 自己テスト・コントローラ10は取り込まれた自己テスト命令に応答して、自己テスト命令が指定する、一連のメモリ・アドレスの生成を含むテスト動作を行う。多数のこのような自己テスト命令を組み合わせることにより、ユーザは総称的自己テスト・コントローラ10を用いて特注のテスト方法を構築できる。



#### 【特許請求の範囲】

【請求項1】 データ処理装置であって、

それぞれのメモリ・アドレスに関連する複数のメモリ記 憶位置を有する少なくとも1個のメモリと、

前記少なくとも1個のメモリの自己テストを制御する自己テスト・コントローラと、を含み、

前記自己テスト・コントローラは自己テスト命令に応答して一連のメモリ記憶位置内の各メモリ位置に少なくとも一度メモリ・アクセスを行い、前記自己テスト命令により選択された前記一連のメモリ記憶位置内で順次にアクセスされるメモリ位置に従ってメモリ・アドレスは変化し、前記自己テスト・コントローラは前記自己テスト命令により形成されて異なるメモリ・テスト方法を実現する、データ処理装置。

【請求項2】 前記自己テスト・コントローラは複数の 自己テスト命令を実行して一連のメモリ・テストを行 い、前記自己テスト命令はプログラム可能であって異な るユーザはメモリ・テストの異なるシーケンスを指定で きる、請求項1記載のデータ処理装置。

【請求項3】 前記メモリ・テストのシーケンスは異なるメモリに適合するように変更できる、請求項2記載のデータ処理装置。

【請求項4】 前記メモリ・テストのシーケンスは異なる製作特性とテスト要求に適合するように変更できる、 請求項2記載のデータ処理装置。

【請求項5】 前記メモリ・アドレスは前記少なくとも 1個のメモリ内の物理的行アドレスと列アドレスであ る、請求項1記載のデータ処理装置。

【請求項6】 前記自己テスト命令は前記少なくとも1 つのメモリ・アクセスの一部として前記メモリに書き込 むデータを指定する、請求項1記載のデータ処理装置。 【請求項7】 前記メモリ・アドレスは前記自己テスト 命令により選択された順次のメモリ位置に従って変化 し、また前記自己テスト・コントローラは次の1つ以上 のメモリ・テスト動作を実行する、すなわち、(i) 指定されたデータを或る範囲内のメモリ・アドレスの全 てのメモリ位置に書き込み、(ii) データを或る範囲 内のメモリ・アドレスの全てのメモリ位置から読み取 り、(iii) 指定されたデータをチェッカー盤パターン のメモリ・アドレスを有するメモリ位置に書き込み、(i データをチェッカー盤パターンのメモリ・アドレ スを有するメモリ位置から読み取り、(v) マーチC メモリ・テストを行い、(vi) メモリ位置の行と列に 配列されたメモリ内の一連のメモリ位置からデータを読 み取りまた指定されたデータを書き込み、メモリ位置の 或る行内のメモリ位置に順にアクセスした後でメモリ位 置の次の行を選択してアクセスし、(vii) メモリ位置 の行と列に配列されたメモリ内の一連のメモリ位置から データを読み取りまた指定されたデータを書き込み、メ モリ位置の或る列内のメモリ位置に順にアクセスした後 でメモリ位置の次の列を選択してアクセスし、(viii) メモリ位置の行と列に配列されたメモリ内の一連のメモ リ位置からデータを読み取り、指定されたデータを書き 込み、またデータを読み取り、メモリ位置の或る行内の メモリ位置に順にアクセスした後でメモリ位置の次の行 を選択してアクセスし、(ix) メモリ位置の行と列に 配列されたメモリ内の一連のメモリ位置からデータを読 み取り、指定されたデータを書き込み、またデータを読 み取り、メモリ位置の或る列内のメモリ位置に順にアク セスした後でメモリ位置の次の列を選択してアクセス し、(x) 一連のメモリ位置において、前記メモリ内 の1つ以上のビット線に或る値を繰り返し書き込み、次 に前記1つまたは複数のビット線を共用するメモリ位置 内に記憶されている相補値を読み取り、(xi) 一連の メモリ位置において、或るメモリ位置から或る値を繰り 返し読み取ると共に逆のデータ書込みを行い、(xii) メーカのテスト方法が特定の要求を持たない実行/不実 行テストについて(i)から(xi)に規定された所定の組み 合わせのメモリ・テスト動作を行い、(xiii) 不合格検 出を有効化するために特定の点で偽読取りデータを生成 する請求項1記載のデータ処理装置。

【請求項8】 プロセッサ・コアを更に備え、前記プロセッサ・コアと前記少なくとも1個のメモリと前記自己テスト・コントローラを1つの集積回路上に形成する、請求項1記載のデータ処理装置。

【請求項9】 前記少なくとも1個のメモリは合成メモリか特注メモリのどちらかである、請求項1記載のデータ処理装置。

【請求項10】 インターフェース回路を前記自己テスト・コントローラと前記少なくとも1個のメモリの間に設け、前記インターフェース回路を通して信号の値とタイミングを前記自己テスト・コントローラと前記少なくとも1個のメモリの間で送って前記少なくとも1個のメモリの異なる値およびタイミング特性に対処する、請求項1記載のデータ処理装置。

【請求項11】 前記インターフェース回路は前記自己 テスト・コントローラが生成したメモリ・アドレス値 を、前記少なくとも1個のメモリに入力する論理アドレ ス値にマッピングする、請求項10記載のデータ処理装 置。

【請求項12】 複数のメモリを備え、前記自己テスト命令は前記自己テスト命令を前記複数のメモリのどれに与えるかを指定する、請求項1記載のデータ処理装置。 【請求項13】 前記自己テスト命令は、検出されたメモリ誤りを前記自己テスト・コントローラが複数の異なる方法のどれを用いて報告するかを指定する、請求項1記載のデータ処理装置。

【請求項14】 前記インターフェース回路は前記少なくとも1個のメモリのテストから得られたデータを収集する結果データ・レジスタを含み、また前記自己テスト

・コントローラは自己テスト命令に応じて結果データを 前記結果データ・レジスタから読み取る、請求項10記 載のデータ処理装置。

【請求項15】 前記自己テスト命令はテスト対象の前 記少なくとも1個のメモリのサイズを指定する、請求項 1記載のデータ処理装置。

【請求項16】 前記自己テスト命令は前記自己テスト・コントローラに直列にロードされる、請求項1記載のデータ処理装置。

【請求項17】 前記少なくとも1個のメモリと前記自己テスト・コントローラを複数個の外部信号ピンを有する集積回路上に形成し、前記自己テスト・コントローラは1つ以上の自己テスト命令を前記自己テスト・コントローラに与えるのに用いる1個以上の外部信号ピンを有する、請求項1記載のデータ処理装置。

【請求項18】 それぞれのメモリ・アドレスに関連する複数のメモリ記憶位置を有するメモリ・テスト方法であって、前記メモリに結合する自己テスト・コントローラに自己テスト命令を与え、前記自己テスト命令に応答して一連のメモリ記憶位置内の各メモリ位置に少なくとも一度メモリ・アクセスを行い、前記自己テスト命令により選択された前記一連のメモリ記憶位置内で順次にアクセスされるメモリ位置に従ってメモリ・アドレスは変化し、前記自己テスト・コントローラは前記自己テスト命令により形成されて異なるメモリ・テスト方法を実現する、ステップを含む、メモリ・テスト方法。

【請求項19】 前記自己テスト・コントローラで複数の自己テスト命令を実行して一連のメモリ・テストを行い、前記自己テスト命令はプログラム可能であって異なるユーザはメモリ・テストの異なるシーケンスを指定できる、請求項18記載のメモリ・テスト方法。

【請求項20】 前記メモリ・テストのシーケンスは異なるメモリに適合するように変更できる、請求項19記載のメモリ・テスト方法。

【請求項21】 前記メモリ・テストのシーケンスは異なる製作特性とテスト要求に適合するように変更できる、請求項19記載のメモリ・テスト方法。

【請求項22】 前記メモリ・アドレスは前記少なくとも1個のメモリ内の物理的行アドレスと列アドレスである、請求項18記載のメモリ・テスト方法。

【請求項23】 前記自己テスト命令は前記少なくとも 1つのメモリ・アクセスの一部として前記メモリに書き 込むデータを指定する、請求項18記載のメモリ・テスト方法。

【請求項24】 前記メモリ・アドレスは前記自己テスト命令により選択された順次のメモリ位置に従って変化し、また前記自己テスト・コントローラは次の1つ以上のメモリ・テスト動作を実行する、すなわち、(i) 指定されたデータを或る範囲内のメモリ・アドレスの全てのメモリ位置に書き込み、(ii) データを或る範囲

内のメモリ・アドレスの全てのメモリ位置から読み取 り、(iii) 指定されたデータをチェッカー盤パターン のメモリ・アドレスを有するメモリ位置に書き込み、(i データをチェッカー盤パターンのメモリ・アドレ スを有するメモリ位置から読み取り、(v) メモリ・テストを行い、(vi) メモリ位置の行と列に 配列されたメモリ内の一連のメモリ位置からデータを読 み取りまた指定されたデータを書き込み、メモリ位置の 或る行内のメモリ位置に順にアクセスした後でメモリ位 置の次の行を選択してアクセスし、(vii) メモリ位置 の行と列に配列されたメモリ内の一連のメモリ位置から データを読み取りまた指定されたデータを書き込み、メ モリ位置の或る列内のメモリ位置に順にアクセスした後 でメモリ位置の次の列を選択してアクセスし、(viii) メモリ位置の行と列に配列されたメモリ内の一連のメモ リ位置からデータを読み取り、指定されたデータを書き 込み、またデータを読み取り、メモリ位置の或る列内の メモリ位置に順にアクセスした後でメモリ位置の次の列 を選択してアクセスし、(ix) メモリ位置の行と列に 配列されたメモリ内の一連のメモリ位置からデータを読 み取り、指定されたデータを書き込み、またデータを読 み取り、メモリ位置の或る列内のメモリ位置に順にアク セスした後でメモリ位置の次の列を選択してアクセス 一連のメモリ位置において、前記メモリ内 の1つまたは複数のビット線に或る値を繰り返し書き込 み、次に前記1つ以上のビット線を共用するメモリ位置 内に記憶されている相補値を読み取り、(xi) 一連の メモリ位置において、或るメモリ位置から或る値を繰り 返し読み取ると共に逆のデータ書込みを行い、(xii) メーカのテスト方法が特定の要求を持たない実行/不実 行テストについて(i)から(xi)に規定された所定の組み 合わせのメモリ・テスト動作を行い、(xiii) 不合格検 出を確認するために特定の点で偽読取りデータを生成す る請求項18記載のメモリ・テスト方法。

【請求項25】 前記少なくとも1個のメモリと前記自 己テスト・コントローラを1つの集積回路上に形成す る、請求項18記載のメモリ・テスト方法。

【請求項26】 前記少なくとも1個のメモリは合成メモリと特注メモリのどちらかである、請求項18記載のメモリ・テスト方法。

【請求項27】 前記自己テスト・コントローラと前記少なくとも1個のメモリの間に送られる信号の値とタイミングは前記自己テスト・コントローラと前記少なくとも1個のメモリの間に設けられたインターフェース回路により処理され、前記少なくとも1個のメモリの異なる値およびタイミング特性に対処する、請求項18記載のメモリ・テスト方法。

【請求項28】 前記インターフェース回路は前記自己 テスト・コントローラが生成したメモリ・アドレス値 を、前記少なくとも1個のメモリに入力する論理アドレ ス値にマッピングする、請求項27記載のメモリ・テスト方法。

【請求項29】 前記自己テスト命令は前記自己テスト命令を前記複数のメモリのどれに与えるかを指定する、 請求項18記載のメモリ・テスト方法。

【請求項30】 前記自己テスト命令は、検出されたメモリ誤りを前記自己テスト・コントローラが複数の異なる方法のどれを用いて報告するかを指定する、請求項18記載のメモリ・テスト方法。

【請求項31】 前記インターフェース回路は前記少なくとも1個のメモリのテストから得られたデータを収集する結果データ・レジスタを含み、また前記自己テスト・コントローラは自己テスト命令に応答して結果データを前記結果データ・レジスタから読み取る、請求項27記載のメモリ・テスト方法。

【請求項32】 前記自己テスト命令はテスト対象の前記少なくとも1個のメモリのサイズを指定する、請求項18記載のメモリ・テスト方法。

【請求項33】 前記自己テスト命令は前記自己テスト・コントローラに直列にロードされる、請求項18記載のメモリ・テスト方法。

【請求項34】 前記少なくとも1個のメモリと前記自己テスト・コントローラを複数個の外部信号ピンを有する集積回路上に形成し、前記自己テスト・コントローラは1つ以上の自己テスト命令を前記自己テスト・コントローラに与えるのに用いる1個以上の外部信号ピンを有する、請求項18記載のメモリ・テスト方法。

## 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明はデータ処理装置の分野に関する。より詳しくは、本発明はメモリ不良を検出するための、データ処理装置内のメモリの自己テストに関する。

# [0002]

【従来の技術】自己テスト機構(組込み自己テスト(BIST)と呼ぶことがある)を持つメモリを組み込んだデータ処理装置は公知である。自己テスト機構とは、メモリ回路を製作したときに一度または一連の自己テストを行ってメモリ不良が存在するかどうかを判定し、存在する場合はその回路を除外することを指示する機構をいう。メモリ回路は高い信頼性が要求されるので、不良回路は正しく識別しなければならない。メモリ・サイズが大きくなるに従って、メモリが占めるダイの部分も大きくなる。またメモリ内のトランジスタの密度が高くなるとメモリの不良密度も非常に大きくなる。

#### [0003]

【発明が解決しようとする課題】不良の種類は設計によって大幅に異なり、また同じ設計でも製造プロセスによって異なる。このため、通常、自己テスト方式は設計や製造方法に従ってメーカが選択する。一般にメーカは、

特定の環境において不良メモリを識別するのに適した、 経験から得られた自社特有の好ましいテスト方法を有す る。或るメーカが採用しているテスト方法は他のメーカ にとって必ずしも適当な方法ではない。

【0004】自己テスト回路はメモリが正しく製作されていることを確かめるのに必要であるが、或る回路領域を占有するのでできるだけ小さくすることが望ましい。自己テスト回路は一般に集積回路を製造するときに用いるが、その後集積回路の通常の動作中には用いない。 【0005】

【課題を解決するための手段】1つの形態では、本発明はデータを処理する装置を提供する。この装置は、それぞれのメモリ・アドレスに関連する複数のメモリ記憶位置を有する少なくとも1個のメモリと、前記少なくとも1個のメモリの自己テストを制御する自己テスト・コントローラと、を含み、前記自己テスト・コントローラは自己テスト命令に応じて一連のメモリ記憶位置内の各メモリ位置に少なくとも一度メモリ・アクセスを行い、前記自己テスト命令により選択された前記一連のメモリ記憶位置内で順次にアクセスされるメモリ位置に従ってメモリ・アドレスは変化し、前記自己テスト・コントローラは前記自己テスト命令により形成されて異なるメモリ・テスト方法を実現する。

【0006】本発明の認識では、アドレス指定の順序を 変えることにより種々のテスト方法を行うことができる プログラム可能な自己テスト・コントローラが望ましい 場合がある。詳しく述べると、かかるプログラム可能な 自己テスト・コントローラを提供することにより、多く の異なるメーカがこの自己テスト・コントローラの設計 を再使用することが可能になり、しかも各メーカがこの 自己テスト・コントローラをプログラムして、自分の特 定の環境に最も適したものとして選択したテスト方法を 実行することが可能になる。単一の固定されたテスト方 法だけを行うコントローラとは異なり、プログラム可能 な自己テスト・コントローラを用いると自己テスト・コ ントローラのサイズと複雑さが増加するので一般に不利 と考えられるが、自己テスト・コントローラ設計を再使 用すれば、異なるメーカの種々のテスト要求や、同じメ ーカであっても独自の製造プロセスを開発したときに生 じる異なるテスト要求などに対処できるので、この不利 を十分補うことができる。

【0007】自己テスト命令が完結したテスト方法を示すことも可能であるが、本発明の好ましい実施の形態では、複数の自己テスト命令を実行して、異なるユーザが異なるシーケンスを指定するように調整された一連のメモリ・テストを行う。自己テスト・コントローラは自己テスト命令のプログラムにより駆動され、特定のユーザが望むあらゆるテスト方法を実行する。理解されるように、テスト対象のメモリの特定の種類に適合するように、または特定の製造テスト方法に適合するように、一

連のメモリ・テストを調整できる。

【0008】理解されるように、自己テスト・コントローラが作成するメモリ・アドレスは種々の形をとってよく、また種々の方法でメモリ位置にマッピングしてよい。しかし多くの種類のメモリ不良はメモリ位置自体の、または他のメモリ位置に対する相対的な物理的位置に関連するので、自己テスト・コントローラが作成するメモリ・アドレスはメモリ位置の物理的位置を与える行と列のアドレスを直接表すものが特に適している。なぜなら、一般にテストの際に有用なメモリ・アドレスのシーケンスは、メモリ・アドレスをこの方法で表現することにより容易に形成できるからである。

【0009】かかるプログラム可能な自己テスト・コントローラにおいて考慮すべき重要な点は、どのアドレス・シーケンスとどのテストを命令が支援するかを決定することである。広範囲の種々の方法で組み合わせて、多くの異なる状況の要求を包含する適用範囲の広いテスト方法を与えるように命令を選択しなければならない。この要求を考慮すると、支援する自己テスト命令の数とそれらが表すテストの複雑さが増加するに従って、自己テスト・コントローラに関連する複雑さとオーバヘッドが増大する。

【0010】上記の要因を考慮して、本発明の好ましい 実施の形態は次のテスト動作を行うことが可能な自己テ スト命令を含む。すなわち、(i) 指定されたデータ を或る範囲内のメモリ・アドレスの全てのメモリ位置に 書き込み、(ii) データを或る範囲内のメモリ・アド レスの全てのメモリ位置から読み取り、(iii) 指定さ れたデータをチェッカー盤パターンのメモリ・アドレス を有するメモリ位置に書き込み、(iv) データをチェ ッカー盤パターンのメモリ・アドレスを有するメモリ位 置から読み取り、(v) マーチC(marchC)メモリ・テ ストを行い、(vi) メモリ位置の行と列に配列された メモリ内の一連のメモリ位置からデータを読み取りまた 指定されたデータを書き込み、メモリ位置の或る行内の メモリ位置に順にアクセスした後でメモリ位置の次の行 を選択してアクセスし、(vii) メモリ位置の行と列に 配列されたメモリ内の一連のメモリ位置からデータを読 み取りまた指定されたデータを書き込み、メモリ位置の 或る列内のメモリ位置に順にアクセスした後でメモリ位 置の次の列を選択してアクセスし、(viii) メモリ位置 の行と列に配列されたメモリ内の一連のメモリ位置から データを読み取り、指定されたデータを書き込み、また データを読み取り、メモリ位置の或る行内のメモリ位置 に順にアクセスした後でメモリ位置の次の行を選択して アクセスし、(ix) メモリ位置の行と列に配列された メモリ内の一連のメモリ位置からデータを読み取り、指 定されたデータを書き込み、またデータを読み取り、メ モリ位置の或る列内のメモリ位置に順にアクセスした後 でメモリ位置の次の列を選択してアクセスし、(x)

一連のメモリ位置において、前記メモリ内の1つ以上のビット線に或る値を繰り返し書き込み、次に前記1つ以上のビット線を共用するメモリ位置内に記憶されている相補値を読み取り、(xi) 一連のメモリ位置において、或るメモリ位置から或る値を繰り返し読み取ると共に逆のデータ書込みを行い、(xii) メーカのテスト方法が特定の要求を持たない実行/不実行(go/nogo)テストについて(i)から(xi)に規定されたメモリ・テスト動作の所定の組み合わせを行い、(xiii) 不合格検出を有効化するために特定の点で偽読取りデータ(false readd ata)を生成する。

【0011】 本発明は、自己テスト・コントローラと 1個以上のメモリとプロセッサ・コアとを1つの集積回路上に形成する実施の形態で用いるのに特に適している。同じ集積回路上に形成する比較的大量のメモリをプロセッサ・コアとして多く用いると、多数のテスト方法を支援する必要が増加する。なぜなら、大量のメモリを含む構成要素のメーカの数が増え、また異なる集積回路に与えられる製作特性の変動も増えるからである。別の観点からすると、メモリは、専門のメモリ・メーカが製作した離散的集積回路の形で与えられることは少なく、広範囲のメーカ(例えばASICメーカ)により種々の他の構成要素(特にプロセッサ・コア)と共に単一の集積回路内に含まれることの方が多いが、この方法はかかる状況における変化に対応する。

【0012】理解されるように、テストの対象となるメモリは種々の異なる形をとる。詳しく述べると、メモリは特定の環境に従って特注のメモリであったり合成メモリであったりする。これらの異なる種類は元来それぞれ異なる検査方法が必要であって、これには自己テスト・コントローラのプログラム可能な性質が有用である。

【0013】本発明の方法を更に複雑にする点は、異なるメモリを駆動するには異なる信号値とタイミングを必要とすることである。比較的簡単な設計の総称的自己テスト・コントローラを作ろうとすると、自己テスト・コントローラ内でかかる違いを処理するのは実用的でない。したがって本発明の好ましい実施の形態は、自己テスト・コントローラとテスト中のメモリの間の必要な信号値とタイミングの調整を行うインターフェース回路を含む。特定のメモリに接続するのに必要な回路要素をまとめて中間のインターフェース回路内に集中することにより、自己テスト・コントローラの設計を総称的にまた比較的コンパクトにできる。

【0014】用いるメモリ・アドレス・シーケンスを指定するだけでなく、自己テスト命令はテスト中にメモリに書き込むデータ値も指定する。データ値の選択は特定のテストにより検出される不良の種類に大きな影響を与え、またこれを用いて特定のメーカまたはユーザが設定できる方法でメモリの潜在的な弱点を探すことができる。

【0015】理解されるように、最近の多くの集積回路 は多数の異なるメモリを含む。これらの異なるメモリの 設計は非常に異なり、異なるテスト方法を必要とする。 自己テスト・コントローラはプログラム可能な性質を持 つので、この単一回路によりかかる異なるメモリをその メモリに最も適した方法でテストできる。また自己テス ト命令は検出された誤りを報告する方法も指定する。こ れは優れた特徴であって、誤り報告を特定のメーカの要 求に合わせ、または設計デバッグと製造テストとを比較 するなど、異なるテスト環境を反映することもできる。 【0016】自己テスト命令の制御の下にアクセス可能 な記憶装置をインターフェース回路が備える場合は、検 出された誤りに関する追加のデータを得ることができ る。これにより自己テスト・コントローラとメモリの間 のインターフェースが簡単になり、しかも特定のユーザ または設計が望む場合は強力な診断またはその他のデー 夕を収集できる。

【0017】異なるキャッシュ・サイズやオンチップR AMサイズなどの種々のメモリ・サイズの共通回路を効率的に処理するため、好ましい実施の形態では自己テスト命令はテスト対象のメモリのサイズを指定する。自己テスト・コントローラに関連する接続オーバヘッドを減らすため、好ましい実施の形態では自己テスト命令を自己テスト・コントローラに直列にロードする。自己テスト・コントローラは集積回路パッケージ上に複数の外部信号ピンを備えて、他の回路要素とは独立に製造テストを行うようにすることが望ましい。

【0018】別の観点から、本発明はそれぞれのメモリ・アドレスに関連する複数のメモリ記憶位置を有するメモリのテスト方法を与える。この方法は、前記メモリに結合する自己テスト・コントローラに自己テスト命令を与え、前記自己テスト命令に応じて一連のメモリ記憶位置内の各メモリ位置に少なくとも一度メモリ・アクセスを行い、前記自己テスト命令により選択された前記一連のメモリ記憶位置内で順次にアクセスされるメモリ位置に従ってメモリ・アドレスは変化し、前記自己テスト・コントローラは前記自己テスト命令により形成されて異なるメモリ・テスト方法を実現する、ステップを含む。【0019】本発明の上記のまたはその他の目的と機能と利点は、例示の実施の形態の以下の詳細な説明を添付の図面と共に読むことにより明らかになる。

#### [0020]

【発明の実施の形態】図1は、プロセッサ・コア4とキャッシュ・メモリ6とRAMメモリ8(この例ではSDRAM)とを含む集積回路2を示す。理解されるように、かかる集積回路2は一般に更に多くの回路要素を含むが、簡単かつ明確にするために、それらの回路要素はこの図から省いた。

【0021】集積回路2上に自己テスト・コントローラ 10があり、それぞれのディスパッチ回路12、14に よりキャッシュ・メモリ6とSDRAMメモリ8とそれぞれ通信する。これらのディスパッチ回路は自己テスト・コントローラ10とそれぞれのメモリの間のインターフェース回路として作用する。これにより、自己テスト・コントローラが生成する総称的メモリ・テスト駆動信号を論理アドレスに再マッピングし、自己テスト・コントローラ10の基本設計を変更せずに、異なるメモリの要求に対して値とタイミングを調整できる。

【0022】また図から分かるように、自己テスト・コントローラ10は集積回路2の多数の外部信号ピンの形で与えられる自己テスト・インターフェース16を含む。このようにして、集積回路2の製作を完了すると適当なテスト・コントローラにプラグインして自己テスト・コントローラ10の自己テスト活動を開始し、メモリ不良を検出すると集積回路2全体を除外するか、または可能であれば回路内で適当な修理を行う。

【0023】図2はテスト・コントローラ10とメモリ 装置18との関係をより詳細に示す略図である。自己テスト・コントローラ10は自己テスト命令レジスタ20を含み、直列シフト法を用いて自己テスト・インターフェース16を介して自己テスト命令をこれにロードできる。自己テスト命令をロードすると、MBIST\_RU Nなどの所定の外部から与えられる信号をアサートすることにより、自己テスト動作が起動する。自己テスト・コントローラ10内ではステートマシン22が自己テスト命令のパターン選択部に応答する。パターン選択部は、自己テスト・コントローラ10がどの物理的メモリ・アドレス・シーケンスを作成してメモリ装置18に与えるかを選択する。

【0024】例えば、選択されたパターンは次の活動を 行う。指定されたデータ語を全ての項目に書き込み、全 ての項目からデータ語を読み取り、チェッカー盤パター ン内のデータ語または反転データ語を全ての項目に書き 込み、チェッカー盤パターン内のデータ語または反転デ ータ語を全ての項目から読み取り、マーチCテストを行 い(この種のテストはメモリ・テストの分野でよく知ら れているのでここではこれ以上を説明しない)、増分減 分語線高速マーチを用いて、読取り動作を行い次に書込 み動作を行い、増分減分ビット線高速マーチを用いて、 読取り動作を行い次に書込み動作を行い、増分減分語線 高速マーチを用いて、読取り動作と書込み動作と読取り 動作を行い、増分減分ビット線高速マーチを用いて、読 取り動作と書込み動作と読取り動作を行い、書込み動作 と読取り動作の繰返しによりビット線対にストレス・テ ストを行う「バング」テストを行い、所定の一連のテス ト (上に述べたテストなど)を行って実行/不実行の結 果を生じ、不合格検出を有効化するために特定の点で偽 読取りデータを生成するパターンを行う。

【0025】上に述べた方法の一部として与えられるデータ語も自己テスト命令内のビット・フィールドとして

与えられる。自己テスト命令内のエンジン制御フィールドは自己テスト・コントローラ10と自己テスト装置全体の誤り報告オプションを定義する。自己テスト命令の配列選択部は、多数のメモリ装置を含む環境において、関係する自己テスト命令でどのメモリ装置をテストするかを選択する。理解されるように、適当な環境では自己テスト命令を多数のメモリ装置に並列に与えることができる。

【0026】自己テスト・コントローラ10は、列アドレス信号と行アドレス信号の形の物理的メモリ・アドレス信号を生成してディスパッチ・コントローラ24に送る。指定されたテストで与えられるデータ語もディスパッチ・コントローラ24に送る。種々の他の制御信号も自己テスト・コントローラ10とディスパッチ・コントローラ24の間で交換される。

【0027】ディスパッチ・コントローラ24は総称的 自己テスト・コントローラ1 0が生成する信号に、必要 な信号値調整またはタイミング調整を与えるインターフ ェース回路として動作する。これはメモリ装置18内で 所望のテストを行うのに必要である。例えば、受けるメ モリ・アクセス命令と実行するメモリ・アクセス命令の 間に異なる長さのパイプライン遅延を挿入することによ り、異なる待ち時間の信号を与える。ディスパッチ・コ ントローラ24の別の重要な役割は、自己テスト・コン トローラ10が生成した物理的メモリ・アドレス信号 を、メモリ装置18を駆動するのに必要な論理的メモリ アドレス信号にマッピングすることである。ディスパ ッチ・コントローラ24が特定のメモリ装置18用に特 に設計された場合は、このマッピングをその設計に含め る。別の実施の形態では、ディスパッチ・コントローラ 24自体が或る程度総称的であって、必要に応じて異な るマッピングを処理できることが望ましい。これをオプ ションで行うには、物理的メモリ・アドレス信号をラッ チし、これを更に別個に設計して設けられたマッピング 回路26に送った後、所望の論理的メモリ・アドレス信 号を返して、ディスパッチ・コントローラ24内でラッ チする。この別個に設けられるマッピング回路26を図 2の点線内に示してこれがオプションであることを示 す。理解されるように、マッピング回路はこのように別 個に設けてもよいし、ディスパッチ・コントローラ24 内に組み込んでもよい。どちらの場合も本発明の方法に 含まれる。

【0028】ディスパッチ・コントローラ24は、メモリ装置18内でテストを行うのに必要な信号値を与える。これらの信号は、論理アドレス値と、データ値(一般に自己テスト命令内で指定されるデータ語の拡張形式である)と、任意の関連する制御信号を含む。またディスパッチ・コントローラ24は、要求されたメモリ・アクセス動作に対するメモリ装置18の応答を監視して、検出されたメモリ不良(読み返された不正なデータ・ビ

ットなど)を自己テスト・コントローラ10に報告する。ディスパッチ・コントローラ24は、全ての検出された誤りまたはその他のパラメータを指定するデータをログするデータ・レジスタを含んでよい。このデータはテストが完了した後で、自己テスト・コントローラ10に取込んだ当該自己テスト命令を用いてディスパッチ・コントローラ24から外部の環境に読み取られる。この種の動作は、誤りの検出に関して細かいレベルの詳細が必要な場合の設計のデバッグに特に有用である。

【0029】図3は、図1と図2に示す実施の形態の動作の概略を示す流れ図である。ステップ28で、自己テスト命令を自己テスト・コントローラ10に直列にロードする。ステップ30で、図2に示すMBIST\_RUN信号を外部から与えて、制御を自己テスト・コントローラ10に渡す。ステップ32で、自己テスト・コントローラ内のステートマシン22は、自己テスト命令レジスタ20内に記憶されている自己テスト命令からパターン選択ビットとエンジン制御ビットとデータ語ビットを読み取り、ステップ34で、指定されたテスト信号を生成する。理解されるように、自己テスト命令は一般に、テスト中のメモリ装置に与えて所望のテスト方法の少なくとも一部を実行する何千もの物理的メモリ・アドレス信号値とデータ値を生成する長いシーケンスを指定する。

【0030】特定の自己テスト命令の実行を完了した 後、ステップ36で、返した結果が合格か不合格かをテ ストをする。不合格の結果を返した場合は処理はステッ プ38に進み、任意の所望の不合格活動をトリガする。 結果が合格の場合はその自己テスト命令を直ぐ終了す る。理解されるように、図3の流れ図は単一自己テスト 命令の実行を示す。実際にはメーカまたはユーザは、特 定の設計および製作環境に特に適したテスト方法を指定 するのに必要な自己テスト命令の長いシーケンスの形で テスト方法を構築するのが普通である。このように多数 の自己テスト命令を自己テスト・コントローラ10にロ ードして、図3に示す処理を多数行う。パターン集合を 制御するのにデータの保持や、外乱の読取りや、idd qテストを行う。理解されるように、ユーザによっては 自分のテスト方法を特注で指定することを希望しないか も知れず、従って、単一自己テスト命令を用いて指定さ れ単一の簡単な実行/不実行の結果値を返す上に述べた 省略時テスト方法に依存するかも知れない。

【0031】図4は自己テスト・コントローラ10から物理的メモリ・アドレス信号40を受ける方法を示す。これはマッピング回路42が処理し、テストするメモリ装置を駆動する適当な論理的メモリ・アドレス信号44を生成する。簡単な装置では、物理的メモリ・アドレス信号を論理的メモリ・アドレス信号に1対1にマッピングする。物理的メモリ・アドレス信号と論理的メモリ・アドレス信号の関係がより複雑な場合もあるが、それで

も設計が比較的簡単で容易なマッピング回路42で達成できる。

【0032】図5は提供されるアドレス信号マッピングの例を示す。テストするメモリ装置は2個のメモリ配列で形成し、それぞれ32行x8列を含む。論理アドレスは9ビット値である。最上位論理アドレス・ビットLA[8]を用いてマルチプレクサを制御して、2個のメモリ配列のどちらかを選択する。論理アドレスの最下位3ビットLA[2:0]を用いて列を選択する。残りの論理アドレス・ビットLA[7:3]を用いて行を選択する。この関係と装置を図5の上部に示す。

【0033】図5の中央部は図2と同じで、マクロセル を示す。マクロセルはSOC設計(自分のSOCインタ ーフェースを有する)の一部であり、また自己テスト・ コントローラ10とディスパッチ・コントローラ24と 上に説明した2ブロックで形成するメモリ装置を含む。 自己テスト・コントローラ10はメモリ装置を、5ビッ トの行アドレスXaddrで表される32行を有するメ モリ位置の配列として処理する。メモリ位置の列は、こ の列が物理的装置内の低次ブロック内にあるか高次のブ ロック内にあるかに関わらず、4ビット・アドレスYa ddrで表される。図5の例では、マッピング回路はS OCインターフェースに取り付けられた特注の回路を介 してディスパッチ・コントローラ24の外部に設けられ る。特注のマッピング回路をこのレベルで取り付けるこ とにより、この回路の変更と設計を容易に行うことがで きる。図に示す例では、物理的メモリ・アドレス信号を ディスパッチ回路24内にラッチし、次に別個のマッピ ング回路に送る。マッピング回路内では、Yaddrフ ィールドの最下位3ビットは論理アドレスの最下位3ビ ットLA[2:0]を形成する。Yaddr値の最上位 ビットは論理アドレスの最上位ビットLA[8]を形成 する。行アドレス5ビット値Xaddrは論理アドレス のビットLA [7:3]を形成する。このようにして構 築された論理アドレスLA [8:0] はマッピング回路 からディスパッチ・コントローラ24に戻されて再びラ ッチされた後、メモリ装置に与えられて所望のテストを 行う。

【0034】上に述べた方法の詳細は次の通りである。 内容

- 1 この文書について
- 1.1 変更履歴
- 1.2 参照文献
- 1.3 用語と略語

2

- 2.1 範囲
- 2.2 概要
- 2.3 MBIST構造
- 2.3.1 概要
- 2.3.2 MBISTユーザ・インターフェース (BIS

Tコントローラへのテスト·アクセス)

2.4 MBIST命令レジスタ

2.4.1 配列イネーブルとフラグ<?:16>(ニブル 増分でなければならない)

2.4.2 データ語<3:0>

2.4.3 パターン/アルゴリズムの選択く9:4>

2.4.3.1 定義

2.4.3.2 BISTパターン仕様

2.4.4 エンジン制御<15:10>

2.5 MBISTメモリ・インターフェース

2.5.1 メモリBISTインターフェース定義

2.5.2 MBISTインターフェース設計規則

2.6 MBISTディスパッチ・ユニット

2.6.1 ディスパッチ・ユニット・インターフェース

2.6.2 アドレス・スクランブリング

2.6.3 サイズ変動

2.7 設計パイロット・プログラム

## 【0035】範囲

この仕様は、メモリBISTをハードおよびソフトのコア製品で実現したものの概要を示す。この仕様はARM内の全ての新設計の青写真となるものであって、最終目的は再使用可能で一定のメモリBIST構造と、全ての顧客(ARM内部を含む)用のメモリBISTインターフェースを作成することである。

## 【0036】概要

メモリBIST構造の機能性はハードおよびソフトのコア内に置く必要がある。なぜなら、メモリ・テスト・インターフェースを非クリティカル・パスに置くのがARMの希望だからである。この目的は、物理的配列からnパイプライン段離れた書込み経路と読取り経路にアクセスすることにより達成される。配列テストの質を最高にするには配列の物理的マッピングが必要であり、またソフト・コアはアドレス・ポートを与えて、物理的形態が分かったときにこれに適合するように最終ユーザがアドレス・ピンを再設定できるようにする。

【0037】ARMはオプションのメモリBISTコントローラをソフト・コアの形で提供し、また特注の形をハード・コアで提供する(オプションではない)。メモリBISTアルゴリズムに関して全ての最終ユーザが自分の考えを持っているのは明らかである。ARMの目的は、種々の不良の程度と種類をテストする標準および特注のアルゴリズムを提供することである。かかるパターンは全ての最終ユーザのテスト方法に完全に適合するわけではないが、最終ユーザが新しい方法を作成する必要がないほど十分な機能を有しているはずである。

【0038】この仕様で注目すべきインターフェースが2つある。第1はユーザ・インターフェースである。ユーザ・インターフェースは将来の拡張を考えて指定する。このインターフェースによりロードされる主命令レジスタと同様に、どのコアでも使い方は同じである。こ

のためどの製品ラインでも見かけや感じが同じである。第2のインターフェースはメモリ・アクセス点に存在する。共通のインターフェースを持つ全ての将来のARMコアについて最終ユーザが自分のBIST方式を設計できるようにすると共に、当社の内部BISTエンジンの要求を満たすためには、種々のコアに共通のインターフェースを持つことが重要である。この文書は配列バイパスまたは制御などの特定のATPGテストのニーズに応えるものではなく、ATPGテスト可能性設計方式に関わらず必要な2つの機能を含むものである。

# 【0039】MBIST構造

#### 概要

ARMメモリBIST方式は物理的にマッピングされた配列でテストを行う機能を中心にして、パターンの有効性を高める。ハード・コアは必ずX次元(行/検出アンプとの間の距離)とY次元(列すなわち検出アンプの選択)に物理的にマッピングされる。ソフト・コアは、メモリ・テスト・インターフェースから、コアとメモリ・インターフェースで与えられる論理アドレスへの文書化されたマッピングを有する。これは、

- 1) インターフェース毎にBIST\_ディスパッチ・ ユニットをスクランブルすることにより物理的マッピン グを行って目的のマッピングに合わせるか、
- 2) コンパイルされたRAM内で強制的に物理的マッピングを行って所定のARMマッピングに合わせる、ためにインテグレータが実行すべきものである(テスト効率を最大にするため)。

【0040】メモリBIST構造は、制御信号をコア内 の全ての配列に分配する単一メモリBISTテスト・エ ンジンを中心とする。コア毎に1つのメモリBISTを 作成すると仮定する。ただし、多数のコアにまたがって エンジンを統合することもできる。コア毎に2個のメモ リBISTエンジンを設けることは可能であるが、テス タとメモリBISTコントローラとの間のテスト・イン ターフェースはシステム・インテグレータが管理し選択 しなければならない。テスト信号の分配と経路選択の影 響は、メモリBISTコントローラから出る4ビットの データ語バスを用いることにより最小になる。データ語 の拡張とテストは、mBIST\_ディスパッチと呼ぶ特 殊なユニットで行われる。これは、メモリBISTコン トローラとメモリBISTテスト・インターフェースと の接着論理(glue logic)として働く。この接着論理は、 アドレス・スクランブリング (物理的空間へのマッピン グ)と、特殊化されたパイプライニング(目標の配列に 対してローカル)と、データ語の比較と、テスト不合格 データロギングを行う。これにより、通常、集中化され たBISTコントローラに関連する過大な経路選択オー

バヘッドを大幅に減らすことができる。

【0041】接着論理を含むディスパッチ・ユニットは 設計に特有の形態を与え、しかもメモリ・テスト・イン ターフェースとBISTコントローラを、どの設計でも 使える固定された標準にすることができる。全ての将来 のARMコアでそのまま再使用可能なBISTコントロ ーラを有することにより、どの設計においても最終ユー ザ・テスト・インターフェースを標準化することができ る。メモリBISTは、メモリBISTインターフェー スへのアクセスを可能にするコアのテスト・インターフ ェースを形成することにより開始する。テスト・アルゴ リズムの進行(アドレス満了フラグにより測定する)と 合格/不合格状態は4ビットの出力専用データ・バス (マクロセルへのポートを有する)で連続的に送られ る。更なるデータロギング情報は、BISTコントロー ラまたは不合格ユニットのディスパッチ・ユニットのシ フト・アクセス (同じ外部 BISTインターフェースを 用いる) により得ることができる。 ディスパッチ・ユニ ット内のデータロギングおよび追跡支援の量は設計に依 存し、また設定可能である。

【0042】各メモリBISTインターフェースは多数の配列を支援することができる。これらの各配列はBIST命令レジスタと不良ログ内で別個の配列として支援される。テストの実行中は、これらの配列もそのイネーブル線をYaddr空間に追加することによりテストすることができる。命令レジスタのイネーブル線により可能になる場合は、BISTディスパッチ・ユニットはイネーブル線をより高いアドレス・ビットにマッピングすることができる。注意すべきであるが、これはこれらの目標配列の直列テストまたは並列テストの通常の定義とは一致せず、配列はより大きな全体配列のセグメントとして処理される。

【0043】図6は、集中化されたBISTコントローラとディスパッチ・ユニットとを示す。MBISTテスト・インターフェースの定義は次の表の通りである。注目すべきは、テスト構成をシフト・ローディングするためのアクセス機構である。このシフト・プロセスはコア・クロック領域で実行される。コアの動作が進行するに従って、低速で手動シフトを行うため(テスタ・インターフェースの制限により)のp11切替え機構と、メモリ・テストを高速で行うため(クロック速度がテスタ・サイクルを超える場合、またはパッド・タイミング制限が最大クロッキング速度を抑える場合)の高速p11クロッキングへの切換えスイッチが必要である。将来の移行経路を支援するためにジャガー(Jaguar)用の4分割シフティング・クロックを形成すると良いかも知れない。

|             | MBISTへのテスト・インターフェース |                         |  |  |  |  |
|-------------|---------------------|-------------------------|--|--|--|--|
| コア・ポート信号    | 說明                  |                         |  |  |  |  |
| MBIST_RUN   | In                  | この信号によりメモリ・テストを開始       |  |  |  |  |
| MBIST_SHIFT | In                  | 制御レジスタにデータのローディング可能     |  |  |  |  |
| MBIST_DIN   | In                  | 制御レジスタへの直列ローディング        |  |  |  |  |
| SCANMODE    | In                  | ディスパッチ・ユニットでのオーバライド禁止   |  |  |  |  |
| MBIST_DOUT  | Out,<3:0>           | ランタイム状態<実行、不合格、X満了、Y満了> |  |  |  |  |

【0044】32クロック用のMBIST\_SHIFTをアサートし、LSBを最初に、MSBを最後に送ることにより、テスト構成を32ビット・レジスタにロードする。このレジスタ・ローディング中はMBIST\_RUNを非活動状態にしなければならない。MBIST\_SHIFTをデアサート(de-asserted)にするとレジスタ・ローディングの実行が終了する。MBIST\_RUNをアサートすると選択されたメモリ・テストを開始し、テストの終了はMBIST\_DOUT<3>ビットで知らせる。テスト中は、MBIST\_DOUT<1:

O>はトグルしてアルゴリズムの進行をマークする。MBIST\_DOUT<2>すなわち不合格ビットはスティッキー(sticky)である。MBIST\_SHIFTはMBIST\_RUNによりゲートされ、エンジン内の未知の危険を防ぐ。MBIST\_DOUT<0>は(MBIST\_SHIFT &~ MBIST\_RUN)のとき命令レジスタのシフト・データ・アウト経路を兼ねる。【0045】MBIST命令レジスタ概要:

|   | <39:24>      | <23:20>   | <19:16>  | <15:10> | <9:4>  | <3:0> |
|---|--------------|-----------|----------|---------|--------|-------|
|   | 配列可能/フラグ     | max Yaddr | maxXaddr | エンジン制御  | パターン選択 | データ語  |
| Ì | ···· · · · · | ≥ 3       | フト方向     |         |        |       |

【0046】配列イネーブルとフラグく39:24>コア内のテストされる各配列はTRM文書の指定に従ってイネーブル・ビットが割り当てられる。これは、全ての配列を並列にテストするか、必要に応じて柔軟に配列を個別にテストするかを示す。例えば、最大パワーの関係からパス当たり50%の配列だけテストする場合がある。別の例では、ATPGまたはiddqで用いるために種々の配列を初期化して種々の背景パターンにする。配列はメモリ・テスト・インターフェースの数で定義されるのではなく、個別にテストされる配列の数により定義される(単一メモリ・テスト・インターフェースは多数の配列イネーブルを有してもよい)。命令レジスタのこの部分は第2の目的も有する。外部のユーザには外部インターフェース上に単一の不良フラグだけが見える。レジスタのこの部分を走査すれば各配列のP/F状態が

分かり、不良配列を更に識別することができる。
【0047】maxYaddr<23:20>
maxYaddrフィールドにより、ユーザはテスト中に用いる最大Yaddr(列アドレスともいう)を指定することができる。種々のキャッシュ・サイズのコア・デリバティブを用いるとき、またはコア内の異なるサイズの配列をテストするとき、これは特に有用である。このBISTコントローラ構造は異なるサイズの多数の配列を同時にテストすることを妨げない。このようなテストを行うには、ユーザは最大配列に等しい最大アドレス・サイズをプログラムし、ディスパッチ・ユニットは小さな配列の範囲外アドレスを阻止する(RE、WEをゲートすることにより)。次の表はレジスタ設定と、その結果のアドレス・サイズを示す。

| MaxYaddr | サイズ | BistYaddr活動ピット[11:0] |
|----------|-----|----------------------|
| 0000     | 0   | 00000000000          |
| 0001     | 2   | 00000000001          |
| 0010     | 4   | 00000000011          |
| 0011     | 8   | 00000000111          |
| 0100     | 16  | 00000001111          |
| 0101     | 32  | 00000011111          |
| 0110     | 64  | 000000111111         |
| 0111     | 128 | 000001111111         |
| 1000     | 256 | 00001111111          |
| 1001     | 512 | 00011111111          |
| 1010     | 1k  | 00111111111          |
| 1011     | 2k  | 01111111111          |
| 1100     | 4k  | 1111111111           |
| >1100    |     | 支援されない               |

【0048】maxXaddr<19:16> Yアドレスと同様に、Xアドレス・フィールドはアドレス指定可能な行の最大数を選択する。ビット線RCのために、512を超える行の深さは通常は実用的でない

が、ユーザがトポロジ内の平面特性をXアドレス空間に マッピングしたい場合は、ここでは最大2kの空間が支 援される(平面すなわちブロック・アドレスはYアドレ ス空間の上にマッピングすることを勧める。さもない

| ٢ | Xアドレス空間に基づくし   | ごいん納フトレフ・ラ  | 7 h ( | の効率が悪くなる)。 |
|---|----------------|-------------|-------|------------|
| C | - 人/ドレス学問に歩づくし | . ツP袋ストレス・フ | ペスト り | リが呼が悪くなる!。 |

| MaxXaddr | サイズ | BistXaddr活動ピット[10:0] |
|----------|-----|----------------------|
| 0000     | 0   | 0000000000           |
| 0001     | 2   | 0000000001           |
| 0010     | 4   | 0000000011           |
| 0011     | 8   | 0000000111           |
| 0100     | 16  | 00000001111          |
| 0101     | 32  | 00000011111          |
| 0110     | 64  | 00000111111          |
| 0111     | 128 | 0000111111           |
| 1000     | 256 | 0001111111           |
| 1001     | 512 | 0011111111           |
| 1010     | 1k  | 0111111111           |
| 1011     | 2k  | 1111111111           |
| 11xx     |     | 支援されない               |

【0049】エンジン制御<15:10> レジスタのエンジン制御部を用いて、特殊なステートマ

シンの行動(不良で停止、など)を指定する。<15: 10>=0という設定は省略時行動を指定する。

| <15:10> | 往頭                          | 說明                                   |
|---------|-----------------------------|--------------------------------------|
| 00 0000 | デフォールト                      | テスト実行の終了                             |
| lx xxxx | 実時間不合格ピット                   | 不合格ピットは実時間、スティッキーな<br>不合格がテストの終わりに出現 |
| RR 0001 | 不合格で停止                      | 16サイクル特ち時間未満の不合格で<br>停止              |
| xx 0010 | 不合格ならアルゴリズムの 終了で<br>停止      | 現在のアリゴリズム「N」が完了後の<br>不合格で停止          |
| 00 1110 | ディスパッチ・ユニット命令の<br>ロード       | 1 ホットく31:16>で選択された<br>ディスパッチ・ユニットを走査 |
| 00 1111 | ディスパッチ・ユニット - ダイア<br>ログの読取り | 1ホットく31:16>で選択された<br>ディスパッチ・ユニットを走査  |

【0050】「実時間不合格ビット」は、テスト/試験室要員がソフト不合格行動を監視したいときに試験室で用いるためのものである。「アルゴリズム・パスの終了で停止」は、不合格アルゴリズム・セグメントの終了までテストを進行させる手段として与えられる。全ての配列項目をダウンロードするためにディスパッチ・ユニットが走査可能なテスト・アクセス機構を備える場合、これはビット・マッピングに有用である。

【0051】ディスパッチ・ユニットを走査すると、選択されたディスパッチ・ユニット走査ポートはMBIST\_DINとMBIST\_DOUTの間に置かれる。MBIST\_RUNがデアサートになるとアクセス禁止になる。ディスパッチ・ユニットにロードされた全ての動作はMBIST\_RUNのデアサートのときに実行される。(注意: 効率を最大にするにはハンドシェイクの定義を改善する必要があり、またmBIST\_RUNなどの特有の機能は暖機サイクルを必要とするので動作を完了するのに十分な時間を与える必要があり、適当なサイクル・カウントだけ内部オーバライド・リリースを遅らせれば

恐らく十分である)。ディスパッチ・ユニットはこのとき緩く定義されており、コアの必要に応じて構築される。ディスパッチ・ユニットは、最初の不合格アドレスや不合格ビットなどの最小のデータロギング情報を与えなければならない。この情報は、ディスパッチ・データログを走査することによりアクセス可能でなければならない。走査可能なディスパッチ・ユニット命令の使用はオプションである。

【0052】パターン/アルゴリズム選択く9:4> 多くの標準パターンとARMが作成したビット線ストレス・パターンがテスト用に設けられている。未知の最終テスト設計で最も柔軟に対応できるように、アルゴリズムは断片的に作成されている。支援されるテストの領域は、実行/不実行、iddq、データ保持、ATPG、総合機能テスト、ストレス・テストなどである。次の表は支援されるパターンを示し、後のパラグラフはその使用法を示す。セグメント化されたテストを用いれば、工場内でのsoftbinおよび歩留まり追跡情報を最大にし、最終テスト設計を工場のメモリ・テストの考え方に最も良く合わせることができる。

| 火班<0:3> | 名前                   | [N] | 設明                                      |  |  |
|---------|----------------------|-----|-----------------------------------------|--|--|
| 00000   | 00000 WriteSolids IN |     | IN 指定されたデータ語を全ての項目に書き込む                 |  |  |
| 00001   | ReadSolida           | 1N  | N 全ての項目からデータ語を試み取る                      |  |  |
| 00010   | WriteCkbd            | IN  | X < 0 > ^ Y < 0 > で選択されたデータまたは<br>データパー |  |  |
| 00011   | ReadCkhd             | 1N  | X < 0 > ^ Y < 0 > で最択されたデータまたは<br>データパー |  |  |
| 00100   | March C+             | 14N | 増分減分XY高速RWRマーチ                          |  |  |
| 00101   | PttnFail             | 6N  | BIST不良検出をテストする                          |  |  |
| 00110   | RW_Xmarch            | 6N  | 増分補分額線高速 マーチ                            |  |  |
| 00111   | RW_Ymarch            | 6N  | 増分減分ピット線高速マーチ                           |  |  |
| 01000   | RWR_Xmarch           | 8N  | 増分は分路線高速 マーチ                            |  |  |
| 01001   | RWR_Ymarch           | 8N  | 増分減分ピット線高速マーチ                           |  |  |
| 01010   | Bang                 | 18N | 増分減分額線高速ビット線ストレス                        |  |  |
| 11111   | Go/No Go             | 30N | 2 *W/RCkbd, RWR Ymarch,<br>X Bang       |  |  |

# [0053]

定義:

列 ビット線に並列の配列の次元 (同じSenseAMP上)

行 語線に並列の配列の次元

行高速/Xfast 目標セルは次の列に移る前にビット線に沿って動く

列高速/Yfast 目標セルは行/語線の前にビット線対をまたがって動く

Xfast増分 目標セルが最も近い検出アンプから離れる

Xfast減分 目標セルが検出アンプから最も違い点から近づく

Yfast増分 Yaddr空間が0から最大まで、東西方向に動く

Xfast減分 Yaddr空間が最大から0まで、増分の逆に動く

N アドレス指定可能な項目の数

【0054】BISTパターン仕様:全てのメモリBI STテストは物理的にマッピングされたアドレス空間に 対して実行される。これは単に、最下位Xaddrが隣 接する行の間で切り替わることを意味する(LSB+1 は2行置きに切り替わる、など)。Yaddr空間も物 理的にマッピングされる。これにより、供給されたパタ ーンでメモリ不良を効率的にまたは直接探すことができ る。「writeCkbd」は実行されたXfastで ある。このパターンは1Nで、書込み専用である。デー 夕極性はxor(Xaddr[0],Yaddr[0])で設定 される。「ReadCkbd」は実行されたXfast である。このパターンは1 Nで、読取り専用である。デ ータ極性はxor(Xaddr(0), Yaddr(0))で設 定される。「writeSolids」は実行されたX fastである。このパターンは1Nで、書込み専用で ある。データ極性=真。「ReadSolids」は実 行されたXfastである。このパターンは1Nで、読 取り専用である。データ極性=真。

【0055】「MarchC+」は次のシーケンスで実行されたXfastである。

- 1) write solids (配列初期化) incr
- 2) Rdata, Wdatabar, Rdatabar incr
- 3) Rdatabar, Wdata, Rdata in cr
- 4) Rdata, Wdatabar, Rdatabar decr
- 5) Rdatabar, Wdata, Rdata de

cr

- 6) Rdata Verify decr 「RWR\_Xmarch」は次のシーケンスで実行され たXfastである。
- 1) Write solid (配列を初期化)
- 2) Rdata/Wdatabar/Rdatabar inc
- 3) Rdatabar/Wdata/Rdata de crement
- 4) Rdata solid

「RWR\_Ymarch」はRWR\_Xmarchと同じシーケンスを有するが実行されたYfastである。 【0056】「RW\_Xmarch」は実行されたXfastである。この6Nパターンは次のシーケンスを有する。

- 1) Write Solid (配列を初期化)
- 2) Rdata/Wdatabar inc
- 3) Rdatabar/Wdata decrement
- 4) Rdata solid

「RW\_Ymarch」は6Nで、RW\_Xmarch と同じシーケンスで実行されたYfastである。「pttnFail」は実行されたXfastである。WriteSolidパターンを実行し、次にReadSolid中にアドレス選択でデータ極性を逆にして注入する。このパターンは、BIST検出論理(目標の配列での)が機能することを確認するのに必要である。

【0057】「bang」は18Nで、実行されたXfastである。ビット線対上で多数の書込みと読取りを連続して実行する。

- 1) write solid (配列を初期化)、
- \* 2) read data target, write databartarget, 6\*write databar row0, increment to next target Xfast
- •• 3) 5•read databar target, write datarow0, read datab ar target, write data target
- 4) read data (配列を確認)。
- \*このセグメントはビット線対を「バング」して、書込み後に正しい等化を保証する。等化/プレチャージが不十分な場合は、同じビット線対から逆のデータを読み取るときに読取りが遅くなる。自己計時するキャッシュでの読取りが遅いと、マーチCのようによく使われる「シングル・ショット」に見られない機能不良が発生する。
  \*\*このセグメントはビットセルを歩き、そのビット線対に逆のデータを書き込み、目標セルのデータを読み取るためのものである。この不良機構は6TのRAMセルでは余り用いられない(4TやDRAMに比べて)。
- \*, \*\*「犠牲的(sacrificial)」行を用いると、グレーコード・パターン・シーケンスがないときに、Xaddr空間内のオープン・デコーダ不良を検出するのに役立つ(デコード・ブロックが小さいのでYaddrは構造的に不良の種類に入らない)。
- \*, \*\*このパターンは不良のスタックも検出するが、その主な目的はメモリのアナログ特性をアドレス指定することである。

【0058】「実行/不実行」、30Nは、最終ユーザが自分のテスト方式を作成することを望まない場合にメモリ・テスト用に選択されるARMテスト・パッケージである。このパターンを選択すると、その後のテストは次に示すリストに従って実行する。これはその配列の合格/不合格状態を最終ユーザに示す。次に示すテスト・パッケージは配列の総合的機能テストを行う(データ保持や他のストレス・テストは含まない)。実行/不実行の一連のテストはメモリ・テストにおける社内のARMメモリ・テスト技術者の過去の経験の集大成である。

- 1) Perform wckbd 5's
- 2) Rckbd 5's
- 3) Wckbd a's
- 4) Rckbd a's
- 5) RWR Ymarch 6's
- 6) Bang 0's

【0059】データ語<3:0>

テスト命令をロードするとき、ユーザはテスト・アルゴリズム中に用いられるルート・データ語を指定する(実行/不実行BISTアルゴリズム中は除く)。これにより、ユーザは初期化された配列内に記憶されている値(iddqまたはATPG)を選択し、または新しいデータ語を選択してマーチおよびビット線ストレス・テスト中の予期しない感度を探すことができる。

【0060】MBISTメモリ・インターフェース メモリ・インターフェースの定義を下の表に示す。AR Mがそのコア用のメモリを提供するかどうかに関わら ず、コア上の全てのメモリ装置でこれを用いる必要があ る。これにより、ユーザはARMのBISTコントロー ラを特に修正せずに用いることができる。ATPG関連 の支援もここに定義されている。

| 信号           | 1/0、サイズ                         | 說明                       |
|--------------|---------------------------------|--------------------------|
| MTestSel     | In, :0                          | オプション、多数の下流の配列の庭列テストに用いる |
| MTestWEx     | ln                              | 者込み動作を命じる                |
| MTestREx     | In                              | 説取り動作を命じろ                |
| MTestADDR*   | In, <maxaddr:0></maxaddr:0>     | 目標アドレス                   |
| MTestDINx    | In, <datawidth:0></datawidth:0> | BIST香込みデータ ′             |
| MTestDOUTy   | Out, < datawidth:0>             | BIST殻取りデータ               |
| MTestON      | In                              | キャッシュ論理のグローバル・オーバライド     |
| ArrayDisable | In                              | 動作モードに関わらず、全ての配列の活動を阻止する |
|              |                                 |                          |

・関係する全てのスクランブリングをmBIST\_ディスパッチが処理する場合は、単一アドレス・バスを有する。

【0061】メモリBISTインターフェースの定義「MTestSe1<?: 0>」

メモリBISTインターフェースが2つ以上の下流の配列を支援する場合は、目標とする配列を選択するのに別個のイネーブルが必要である。この信号は多数の修理可能な領域を有する単一配列にも必要である。単一配列インターフェースはこの信号の使用またはポートを必要としない。

「MTestWEx」

この信号は(MTestSelまたはMTestONにより内部で阻止されない場合は)メモリ・テスト配列インターフェースに書込み動作を実施中であることを示す。アドレスおよびデータ情報はこの信号と同時に送られる。書込み動作を完了するのに2サイクルかかる場合は、この信号を「MTestWE2」で表す。多数の配列がそのインターフェースで支援される場合(全てが異なるパイプライン遅延を有する)はxを用いる(「MTestWEx」)。信号名の中にパイプライン遅延の長さを用いることにより、BISTインターフェース・ユ

ニットまたは最終ユーザ自身によるBIST統合が容易になる。

[0062] MTestREx」

テスト中の配列の読取りイネーブルである。詳細はMTestWEx信号を参照のこと。

 $\lceil MTestADDR < ?: 0 > \bullet \rfloor$ 

テスト中の配列内の目標アドレスである。信号の広さは 目標配列内のアドレス指定可能な要素の最大数と同じで ある。

[0063] [MTestDINx, MTestDOUTy]

BIST動作のためのデータイン・ポートとデータアウト・ポートである。MBISTDOUTは、MBIST RExの定義に従って「x+y」サイクル後に送られる。例:MBISTRE3は、MBISTRE3情報がアサートされてから3クロック後に読取り動作を行うことを指定する。データアウト・パイプラインは自身のオフセットを有し、これを「y」で表す。多数の配列が単一のインターフェースで支援され、またいくつかの配列のデータ幅が最大配列幅より小さい場合は、全ての読取り動作において全ての未使用データ・ビットで「O」を送ることがメモリBISTインターフェースに要求される。データイン・バスとデータアウト・バスが下流の配列に依存して種々のパイプライン・オフセットを有する場合は、「x」を用いてオフセットを指定しなければならない。

# [0064] [MTestON]

これはグローバル・オーバライド信号で、BIST動作が直ぐ起こることをインターフェースと下流の論理に知らせる。この信号は、キャッシュ論理内でScanMode/ScanEnに次いで2番目に優先度の高い信号である。正規関数/ミッション・モード動作の優先度は更に低い。

### 「ArrayDisable」

ATPG信号であって、これが活動状態のときは全ての配列への書込みと読取りを阻止する。配列の初期化データの安全を保証するため、阻止は全ての走査可能な状態要素の後に行わなければならない。この信号はメモリBISTディスパッチ・ユニット内で生成され、IDDQtestとScanEnの「論理和」関数である。IDDQtestはiddq走査および収集中に状態を保存するのに用いられ、ScanEnはATPGのRAMテストを行うときにATPGロード/アンロード中の状態を保存するのに用いられる。\*関係する全てのスクランブリングをmBIST\_ディスパッチが処理する場合には、単一アドレス・バスを有する。これは研究中である。

【0065】MBISTインターフェース設計規則 ・ MTestONは全ての正規関数動作をオーバライ ドする。

- ・ MTestONは最初の動作の少なくとも4サイク ル前にアサートされ、最後の動作が完了するまで解除されない。BISTテスト期間中は[オン]のままである
- · 装置モード (関数、ATPG、BISTなど) に関わらず、ArrayDisableは全ての書込み/読取り活動を阻止し、最後の操作可能な状態要素の後に起こる。
- ・ BISTノーオペレーションが起こることがある。 RE/WEが共に非活動状態のときのBISTサイクル として定義される。
- · バック・ツー・バック動作を支援しなければならない。これはR/W/Addrの任意の組合わせで予想される。
- · F/Fから与えられる全ての動作データと、読取り データとは、F/F内にサンプリングされる(mBIS Tはフロップに基づく設計である)。
- · 全てのBIST動作は最高速度で起こり得る。
- ・ Addr信号とRE/WE信号は同じクロック・サイクルで与えられる。必要であればデータインは異なる段階で注入してよい。
- ・ 全てのRE/WE/Data信号は信号記述で指定 されたサイクル接尾部指示子を有しなければならない。
- ・ 全ての読取り動作はREアサートからデータアウト まで8サイクル以内に完了しなければならない (パイプ ライン注入点は妥当な点でなければならない)。

【0066】・ 多数の配列がインターフェースで支援される場合は、アドレスとデータの調整はディスパッチ・ユニットで行う(例: アドレス指定された配列はBIST\_エンジンより小さい……BIST\_ディスパッチは範囲外のアドレスについてRE/WEを阻止する)。

- ・ 最も右のビットがLSBである到着BISTADD Rにwrtをアドレス指定するときは、全ての可変サイズの配列を右に整えなければならない。
- ・ 動作の設定/保持時間に関係なく、ArrayDisableとMTestONだけをトグルすると仮定してよい。インターフェースでの全ての他の制御信号は各サイクルで未知と考えなければならない。
- ・ mBISTインターフェースと実際の配列インターフェースの間でアドレス
- ・スクランブリングを行ってはならない。スクランブリングはディスパッチ・ユニットで行う。
- ・ 各特有の配列インターフェースの下流の全ての配列 で物理的マッピング特性を保持しなければならない(配 列が所定のインターフェースで支援されるかどうかに関 わらず、XaddrのLSBは常に隣接行の間で選択す る)

【0067】MBISTディスパッチ・ユニット 各BISTコントローラとメモリ・テスト・インターフ ェースの間にディスパッチ・ユニットが必要である。このブロックは、標準化されたフロントエンドBISTコントローラと標準化されたメモリ・テスト・インターフェースの間の接着論理として働く。また配列への手動デバッグ・アクセスに用いられ、またテスト・インターフェースから読み取ったデータの比較とデータロギングを

行う。

【0068】 ディスパッチ・ユニット・インターフェー ス

次の表はmBIST\_ディスパッチ・ユニットの入力および出力インターフェース信号を示す。

| 信号             | 說明                      | 信号           | ・インターフェース への 1 / 出力<br>説明 |
|----------------|-------------------------|--------------|---------------------------|
| ArrayEn :0     | 目標配列可能 (命令 レジスタ)        | MTestSel     | インターフェースへの配列可能            |
| BISTTest       | ゲーム・オン                  | MTestWEx     | 配列告込み可能                   |
| MBISTData<3:0> | データの舎込み/読取り             | MTestREx     | 配列読取り可能                   |
| MBISTXaddr :0  | BISTコントローラ語線アドレス        | MTestADDR*   | 配列セル選択                    |
| MBISTYaddr :0  | BlsTコントローラ・ビット線<br>アドレス |              |                           |
| MBISTWE        | BISTコントローラ書込み可能         | MTestDINx    | 配列データイン (全幅)              |
| MBISTRE        | BISTコントローラ読取り可能         | MTestDOUTy   | 配列データアウト (全幅)             |
| MBISTShift     | ディスパッチ命令のシフト可能          | MTestON      | 配列テスト・オーバライド              |
| MBISTShiftD    | データログのシフト可能             | ArrayDinable | 配列アクセス阻止                  |
| DispatchDin    | シフト・データイン               |              |                           |
| DispatchDout   | シフト・データアウト              | i            |                           |
| lddqTest       | iddgテスト・モード             |              |                           |
| SE             | 走查可能入力                  | İ            |                           |
| SCANMODE       | ATPGテスト・モード             |              |                           |
| MBISTFail :0   | 主コントローラに送られる不合格<br>ビット  |              |                           |

#### 【0069】注:

- 1. BISTData<3:0>は全メモリ・ビット幅にわたって直線的に拡張される。ディスパッチ・ユニット内でのこのデータのパイプライニングは<3:0>として行われ、必要に応じて拡張される。この拡張語を用いて、テスト中のメモリの全バス幅を駆動しまたは比較する。
- 2. DispatchDoutはディスパッチ・ユニットの命令レジスタまたはデータログ・レジスタのLS Bに続く(シフト・イネーブルにより選択される)。 3. 全ての定義された信号について、メモリ・テスト
- ・インターフェースはディスパッチ・ユニットで、そして ディスパッチ・ユニットだけで駆動しなければならない (BISTコントローラに直接接続しない。なぜなら、 ディスパッチ・ユニットはタイミングの安全のためにコ ントローラ・データをパイプラインするからである)。
- 4. ディスパッチ内の命令レジスタ機能の支援は、設計に特有である。データロギング/修理の情報はディスパッチ・ユニット内で生成され保持され、設計に特有である。
- 5. 多数のイネーブルが選択した配列は、イネーブル を高次のYaddrにマッピングすることにより同時に テストすることができる。これは実行/不実行のテスト に非常に望ましい。

【0070】アドレス・スクランブリング ハード・コアは既知の物理アドレス空間から論理アドレ ス空間へのマッピングを有し、これに従ってBIST\_

ディスパッチ・ユニット内でスクランブルする必要があ る。これはディスパッチ・ユニットで行う。なぜなら、 アドレス・スクランブルの要求はメモリ・テスト・インタ ーフェースによって異なるからである。ソフト・コアと コンパイルされたRAMは既知のアドレス指定アップフ ロントを有しないので、特にメモリをコンパイルする前 にコア設計を合成する場合は、スクランブリングをrt 1で行うことはできない。スクランブリングは、物理的 マッピングがARMのBISTアルゴリズムと共に存在 することを確認する必要がある。これは、TestAd drの2つの追加のポートをディスパッチ・ユニットに 加えることにより行う。1つはBISTコントローラ・ アドレスを表し、もう1つはMTestAddrインタ ーフェースに行くアドレスのスクランブルされたものを 表す。これらのポートは設計の最高ハード化レベルに上 げ、必要に応じてコントローラ・アドレスをテスト・ア ドレスにステッチする(stitching)ことによりスクラン ブリングを行う。この組込みはコア・インテグレータが 行う。

【0071】添付の図面を参照して本発明の例示の実施の形態を詳細に説明したが、理解されるように、本発明はこれらの実施の形態に制限されるものではなく、当業者は特許請求の範囲に規定されている本発明の範囲と精神から逸れることなく種々の変更や修正を行うことができる。

## 【図面の簡単な説明】

【図1】プロセッサ・コアと多数のメモリと自己テスト

・コントローラを組み込んだ集積回路の略図。

【図2】自己テスト・コントローラとインターフェース 回路とメモリの詳細の略図。

【図3】図2の自己テスト・コントローラの使用の概要を示す流れ図。

【図4】物理的メモリ・アドレス信号から論理的メモリ・アドレス信号へのマッピングの概要を示す図。

【図5】必要なアドレス信号マッピングの例の詳細を示

す図。

【図6】集中化されたBISTコントローラとディスパッチ・ユニットとを示す図。

【符号の説明】

4 プロセッサ・コア

6 キャッシュ・メモリ

8 RAMメモリ

10 自己テスト・コントローラ

【図1】



【図2】





# フロントページの続き

- (72)発明者 スティーブン ジョン ヒル アメリカ合衆国 テキサス、オースティ ン、 サウスウェスト パークウェイ 5604 ナンバー 2234
- (72)発明者 ジェラード リチャード ウィリアムス ザ サード アメリカ合衆国 テキサス、サンセット ヴァリー、 カーリー メスキート コー ブ 3
- Fターム(参考) 2G132 AA08 AK07 AK13 AK29 5B018 GA03 HA01 JA21 JA22 NA02 5B062 CC01 DD10 JJ05 5L106 AA16 DD22 DD23 EE02 GG07